## **Combinational Circuit Design**

Design the following circuits using Verilog and create a testbench for each design to check its functionality.

1)

- The design has 5 inputs and 2 outputs
- Randomize the stimulus in the testbench and make sure that the output is correct from the waveform



2) Design a 4-bit priority encoder, the following truth table is provided where x is 4-bit input and y is a 2-bit output. Randomize the stimulus in the testbench and add an expected result y in your testbench code and make the testbench self-checking.

| y0 | y <b>1</b> | x0 | <b>x1</b> | x2 | х3 |
|----|------------|----|-----------|----|----|
| 1  | 1          | Х  | Х         | Х  | 1  |
| 0  | 1          | X  | Χ         | 1  | 0  |
| 1  | 0          | X  | 1         | 0  | 0  |
| 0  | 0          | Χ  | 0         | 0  | 0  |

3) Design a decimal to BCD "Binary Coded Decimal" encoder has 10 input lines D0 to D9 and 4 output lines Y0 to Y3. Below is the truth table for a decimal to BCD encoder. Output should be held LOW if none of the following input patterns is observed. Randomize the stimulus in the testbench and add an expected result y in your testbench code and make the testbench self-checking.

| Input          |                |                |       |       |       |       |       |       |       | Output         |                |                |    |
|----------------|----------------|----------------|-------|-------|-------|-------|-------|-------|-------|----------------|----------------|----------------|----|
| D <sub>9</sub> | D <sub>8</sub> | D <sub>7</sub> | $D_6$ | $D_5$ | $D_4$ | $D_3$ | $D_2$ | $D_1$ | $D_0$ | Y <sub>3</sub> | Y <sub>2</sub> | Y <sub>1</sub> | Yo |
| 0              | 0              | 0              | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0              | 0              | 0              | 0  |
| 0              | 0              | 0              | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0              | 0              | 0              | 1  |
| 0              | 0              | 0              | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0              | 0              | 1              | 0  |
| 0              | 0              | 0              | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0              | 0              | 1              | 1  |
| 0              | 0              | 0              | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0              | 1              | 0              | 0  |
| 0              | 0              | 0              | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0              | 1              | 0              | 1  |
| 0              | 0              | 0              | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0              | 1              | 1              | 0  |
| 0              | 0              | 1              | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0              | 1              | 1              | 1  |
| 0              | 1              | 0              | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1              | 0              | 0              | 0  |
| 1              | 0              | 0              | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1              | 0              | 0              | 1  |

- 4) Implement N-bit adder using Dataflow modeling style
  - The design takes 2 inputs (A, B) and the summation is assigned to output (C) ignoring the carry.
  - Parameter N has default value = 1.
  - Randomize the stimulus in the testbench and add an expected result y in your testbench code and make the testbench self-checking.
- 5) Design N-bit ALU that perform the following operations
  - The design has 3 inputs and 1 output
  - Instantiate the half adder from the previous question to implement the addition operation of the ALU
  - For the subtraction, subtract B from A "A B"
  - Parameter N has default value = 4.
  - Randomize the stimulus in the testbench and add an expected result y in your testbench code and make the testbench self-checking.

| 4 | Inp | outs | Outputs     |
|---|-----|------|-------------|
|   | opc | ode  | Operation   |
|   | 0   | 0    | Addition    |
|   | 1   | 0    | Subtraction |
|   | 0   | 1    | OR          |
|   | 1   | 1    | XOR         |



FACEBOOK GRP: DIGITAL ELECTRONICS COURSES (VERILOG) MOBILE NO.: 01009279775

## 6) Implement 4-bit ALU display on 7 Segment LED Display

- The design has 4 inputs: A, B, opcode, enable.
- The design has 7 outputs (a-g)
- Instantiate the N-bit ALU designed in the previous question with parameter N = 4
- ALU should execute the operation on A and B depending on the input opcode
- ALU output should be considered as the digit to be displayed on the 7 segment LED display
- Below the truth table of the 7-segment decoder
- Since we have verified the ALU and Adder, we need to make sure that the outputs a to g are correct. Write 16 directed test vectors to exercise all the below digits with enable input equals to 1 then one directed test vector to drive the enable to 0. Make the testbench self-checking.

|                      | Input                       |              |           |          | Output |       |          |           |
|----------------------|-----------------------------|--------------|-----------|----------|--------|-------|----------|-----------|
| Digit                | enable                      | a            | b         | С        | d      | e     | f        | g         |
| 0                    | 1                           | 1            | 1         | 1        | 1      | 1     | 1        | 0         |
| 1                    | 1                           | 0            | 1         | 1        | 0      | 0     | 0        | 0         |
| 2                    | 1                           | 1            | 1         | 0        | 1      | 1     | 0        | 1         |
| 3                    | 1                           | 1            | 1         | 1        | 1      | 0     | 0        | 1         |
| 4                    | 1                           | 0            | 1         | 1        | 0      | 0     | 1        | 1         |
| 5                    | 1                           | 1            | 0         | 1        | 1      | 0     | 1        | 1         |
| 6                    | 1                           | 1            | 0         | 1        | 1      | 1     | 1        | 1         |
| 7                    | 1                           | 1            | 1         | 1        | 0      | 0     | 0        | 0         |
| 8                    | 1                           | 1            | 1         | 1        | 1      | 1     | 1        | 1         |
| 9                    | 1                           | 1            | 1         | 1        | 1      | 0     | 1        | 1         |
| A                    | 1                           | 1            | 1         | 1        | 0      | 1     | 1        | 1         |
| b                    | 1                           | 0            | 0         | 1        | 1      | 1     | 1        | 1         |
| С                    | 1                           | 1            | 0         | 0        | 1      | 1     | 1        | 0         |
| d                    | 1                           | 0            | 1         | 1        | 1      | 1     | 0        | 1         |
| E                    | 1                           | 1            | 0         | 0        | 1      | 1     | 1        | 1         |
| F                    | 1                           | 1            | 0         | 0        | 0      | 1     | 1        | 1         |
| х                    | 0                           | 0            | 0         | 0        | 0      | 0     | 0        | 0         |
| A [3<br>B [3         | 7                           | Re           | sult [3:0 |          | 8      |       | 38<br>86 | 88<br>88( |
| FACEBOOK<br>MOBILE N | ( GRP: DIGITA<br>O.: 010092 | /<br>pcode [ | 1:0]      | VERILOG) | 7-     | segme | nt deco  | oder      |

## Deliverables:

- 1) The assignment should be submitted as a PDF file with this format <your\_name>\_Assignment2 for example Kareem\_Waseem\_Assignment2
- 2) Snippets from the waveforms captured from QuestaSim for each design with inputs assigned values and output values visible

Note that your document should be organized as 6 sections corresponding to each design above, and in each section, I am expecting the Verilog code for the design, testbench and the waveforms snippets